package cn.kgc.gmall.app.func;

import cn.kgc.gmall.utils.KeywordUtil;
import org.apache.flink.table.annotation.DataTypeHint;
import org.apache.flink.table.annotation.FunctionHint;
import org.apache.flink.table.functions.TableFunction;
import org.apache.flink.types.Row;

import java.util.List;

/**
 * 自定义UDTF函数
 * @FunctionHint: 代表你可以定义多个自定义类型的重载方法 只要返回值是row里面的类型就行
 */
@FunctionHint(output = @DataTypeHint("ROW<s STRING>"))
public  class KeywordFunction extends TableFunction<Row> {

    public void eval(String word) {
        // 调用ik分词器
        List<String> analyze = KeywordUtil.analyze(word);
        for (String str : analyze) {
            collect(Row.of(str));
        }
    }


}
